<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>组件的data为什么是一个函数</title>
</head>
<script src="../js/vue.js"></script>
<body>

<h2>返回一个函数，可以保证每个组件的复用的时候不会相互影响，如果不返回一个函数，那么就会出现
    修改一个组件的值，那么就会修改所有组件的值，这样其实是我们不想要的</h2>

<!-- 组件实例 -->
<div id="app">
    <cpn></cpn>
</div>


</body>

<template id="cpn">
    <div>
        <h1>dasdasdasda</h1>
        <h2>{{count}}</h2>
        <button @click="add()">+</button>
        <button @click="decrement">-</button>
    </div>
</template>

<script>

    Vue.component('cpn', {
        template: '#cpn',
        data() {
            return {
                count: 0
            }
        },
        methods: {
            add() {
                return this.count++;
            },
            decrement() {
                return this.count--;
            }
        }
    });

    const vue = new Vue({
        'el': '#app',
        'data': {},
        'methods': {}
    })
</script>
</html>